# MCUXpresso SDK Release Notes Supporting twrkm34z50mv3

**Change Logs** 



# **Contents**

# **Driver Change Log**

| CLOCK                                         | 1  |
|-----------------------------------------------|----|
| 12C                                           | 1  |
| SPI_CMSIS · · · · · · · · · · · · · · · · · · | 1  |
| UART · · · · · · · · · · · · · · · · · · ·    | 2  |
| ADC16                                         | 2  |
| <b>AFE</b>                                    | 3  |
| CMP · · · · · · · · · · · · · · · · · · ·     | 3  |
| COMMON · · · · · · · · · · · · · · · · · · ·  | 3  |
| CRC·····                                      | 5  |
| DMA                                           | 6  |
| DMAMUX · · · · · · · · · · · · · · · · · · ·  | 6  |
| EWM·····                                      | 7  |
| FLASH · · · · · · · · · · · · · · · · · · ·   | 7  |
| GPIO                                          | 8  |
| I2C                                           | 10 |
| IRTC · · · · · · · · · · · · · · · · · · ·    | 11 |
| LLWU·····                                     | 12 |
| LPTMR · · · · · · · · · · · · · · · · · · ·   | 13 |
| PIT · · · · · · · · · · · · · · · · · · ·     | 13 |
| PMC                                           | 14 |

| Title                                                     | Page | No. |
|-----------------------------------------------------------|------|-----|
| PORT ····                                                 |      | 14  |
| QTMR · · · · · · · · · · · · · · · · · · ·                |      | 15  |
| RCM · · · · · · · · · · · · · · · · · · ·                 |      | 15  |
| SIM                                                       |      | 16  |
| SLCD ·····                                                |      | 16  |
| SMC                                                       |      | 17  |
| SPI                                                       |      | 17  |
| SPI DMA Driver · · · · · · · · · · · · · · · · · · ·      |      | 19  |
| SPI FreeRTOS Driver · · · · · · · · · · · · · · · · · · · |      | 20  |
| UART                                                      |      | 21  |
| UART_DMA·····                                             |      | 23  |
| UART_FREERTOS · · · · · · · · · · · · · · · · · · ·       |      | 23  |
| VREF ····                                                 |      | 23  |
| WDOG                                                      |      | 24  |
| XBAR · · · · · · · · · · · · · · · · · · ·                |      | 24  |
| Component Change Log                                      |      |     |
| SERIAL_MANAGER · · · · · · · · · · · · · · · · · · ·      |      | 25  |

# 1 Driver Change Log CLOCK

Current CLOCK driver version is 2.0.0

- 2.0.0
  - Initial version.

#### I<sub>2</sub>C

Current I2C CMSIS driver version is 2.2.0

- 2.2.0
  - Bug Fixes
    - \* Fixed the MISRA-2012 violations.
      - · Fixed rule 8.4, 8.6, 10.1, 10.3, 10.4, 11.1, 11.8, 14.4, 16.1, 16.3, 17.7, 17.3, 17.7, 20.9.
- 2.0.1
  - Bug Fixes
    - \* In ARM\_I2C\_ABORT\_TRANSFER operation in I2C\_InterruptControl, the method to check if I2C is operating as slave is not correct, then master may have potential risk to block at the slave check code.
- 2.0.0
  - Initial version.

# SPI\_CMSIS

Current spi\_cmsis driver version is 2.3

- 2.3
  - Bug Fixes
    - \* Fixed the MISRA-2012 violations.
      - Fixed rule 8.4, 8.6, 10.1, 10.3, 10.4, 10.8, 11.8, 11.9, 14.4, 16.1, 16.3, 16.4, 17.7, 20.9.
- 2.2
  - Bug Fixes
    - \* Fixed the bug that, the parameter num of APIs ARM\_SPI\_Transfer, ARM\_SPI\_Send and ARM\_SPI\_Receive, and the return value of API ARM\_SPI\_GetDataCount should be the number of data item defined by datawidth, rather than the number of byte.
- 2.1
  - Bug Fixes
    - \* Fixed the wrong clock polarity assignment in driver. For ARM\_SPI\_CPOL0\_CPHA0 and other frame format parameters, CPOL = 0 means kSPI\_ClockPolarityActiveHigh not kSPI\_ClockPolarityActiveLow in driver.

MCUXpresso SDK Release Notes Supporting twrkm34z50mv3, Rev 2.12.0, 7/2022

- New features
  - \* Added new feature to support 3-wire mode for both master and slave instance. User can use ARM\_SPI\_MODE\_MASTER\_SIMPLEX to set the MOSI pin as output/input pin, and use the ARM\_SPI\_MODE\_SLAVE\_SIMPLEX to set the MISO pin as output/input pin.
  - \* Allowed user to set up the default transmit value by using ARM\_SPI\_SET\_DEFAULT\_TX\_VALUE.
- 2.0
  - Initial version.

### **UART**

The current UART CMSIS driver version is 2.1

- 2.1
  - Bug Fixes
    - \* Fixed the MISRA-2012 violations.
      - Fixed rule 8.48.610.110.310.411.111.914.415.716.116.316.416.617.720.720.9.
- 2.0
  - Initial version.

### ADC<sub>16</sub>

The current ADC16 driver version is 2.3.0.

- 2.3.0
  - Improvements
    - \* Added new API ADC16\_EnableAsynchronousClockOutput() to enable/disable ADACK output.
    - \* In ADC16\_GetDefaultConfig(), set enableAsynchronousClock to false.
- 2.2.0
  - Improvements
    - \* Added hardware average mode in adc\_config\_t structure, then the hardware average mode can be set by invoking ADC16\_Init() function.
- 2.1.0
  - New Features:
    - \* Supported KM series' new ADC reference voltage source, bandgap from PMC.
- 2.0.3
  - Bug Fixes
    - \* Fixed IAR warning Pa082: the order of volatile access should be defined.
- 2.0.2
  - Improvements
    - \* Used conversion control feature macro instead of that in IO map.
- 2.0.1

- Bug Fixes
  - \* Fixed MISRA-2012 rules.
    - · Rule 16.4, 10.1, 13.2, 14.4 and 17.7.
- 2.0.0
  - Initial version

# **AFE**

The current AFE driver version is 2.0.2.

- 2.0.2
  - Bug Fixes
    - \* Fixed MISRA C-2012 rule 10.1, rule 10.4 and so on.
- 2.0.1
  - Improvements
    - \* Changed type modifiers from const xx\_Type \* s\_xxBases to xx\_Type \*const s\_xxBases.
    - \* Added static modifier for s\_xxx variables defined in drivers.
- 2.0.0
  - Initial version.

# **CMP**

The current CMP driver version is 2.0.2.

- 2.0.2
  - Bug Fixes
    - \* Fixed the violations of MISRA 2012 rules:
      - · Rule 10.3
- 2.0.1
  - Bug Fixes
    - \* Fixed MISRA-2012 rules.
      - · Rule 14.4, rule 10.3, rule 10.1, rule 10.4 and rule 17.7.
- 2.0.0
  - Initial version.

# **COMMON**

The current COMMON driver version is 2.3.2.

- 2.3.2
  - Improvements
    - \* Make driver aarch64 compatible
- 2.3.1
  - Bug Fixes

- \* Fixed MAKE VERSION overflow on 16-bit platforms.
- 2.3.0
  - Improvements
    - \* Split the driver to common part and CPU architecture related part.
- 2.2.10
  - Bug Fixes
    - \* Fixed the ATOMIC macros build error in cpp files.
- 2.2.9
  - Bug Fixes
    - \* Fixed MISRA C-2012 issue, 5.6, 5.8, 8.4, 8.5, 8.6, 10.1, 10.4, 17.7, 21.3.
    - \* Fixed SDK\_Malloc issue that not allocate memory with required size.
- 2.2.8
  - Improvements
    - \* Included stddef.h header file for MDK tool chain.
  - New Features:
    - \* Added atomic modification macros.
- 2.2.7
  - Other Change
    - \* Added MECC status group definition.
- 2.2.6
  - Other Change
    - \* Added more status group definition.
  - Bug Fixes
    - \* Undef \_\_VECTOR\_TABLE to avoid duplicate definition in cmsis\_clang.h
- 2.2.5
  - Bug Fixes
    - \* Fixed MISRA C-2012 rule-15.5.
- 2.2.4
  - Bug Fixes
    - \* Fixed MISRA C-2012 rule-10.4.
- 2.2.3
  - New Features
    - \* Provided better accuracy of SDK\_DelayAtLeastUs with DWT, use macro SDK\_DELA-Y\_USE\_DWT to enable this feature.
    - \* Modified the Cortex-M7 delay count divisor based on latest tests on RT series boards, this setting lets result be closer to actual delay time.
- 2.2.2
  - New Features
    - \* Added include RTE\_Components.h for CMSIS pack RTE.
- 2.2.1
  - Bug Fixes
    - \* Fixed violation of MISRA C-2012 Rule 3.1, 10.1, 10.3, 10.4, 11.6, 11.9.
- 2.2.0
  - New Features
    - \* Moved SDK\_DelayAtLeastUs function from clock driver to common driver.

- 2.1.4
  - New Features
    - \* Added OTFAD into status group.
- 2.1.3
  - Bug Fixes
    - \* MISRA C-2012 issue fixed.
      - · Fixed the rule: rule-10.3.
- 2.1.2
  - Improvements
    - \* Add SUPPRESS\_FALL\_THROUGH\_WARNING() macro for the usage of suppressing fallthrough warning.
- 2.1.1
  - Bug Fixes
    - \* Deleted and optimized repeated macro.
- 2.1.0
  - New Features
    - \* Added IRQ operation for XCC toolchain.
    - \* Added group IDs for newly supported drivers.
- 2.0.2
  - Bug Fixes
    - \* MISRA C-2012 issue fixed.
      - · Fixed the rule: rule-10.4.
- 2.0.1
  - Improvements
    - \* Removed the implementation of LPC8XX Enable/DisableDeepSleepIRQ() function.
    - \* Added new feature macro switch "FSL\_FEATURE\_HAS\_NO\_NONCACHEABLE\_S-ECTION" for specific SoCs which have no noncacheable sections, that helps avoid an unnecessary complex in link file and the startup file.
    - \* Updated the align(x) to **attribute**(aligned(x)) to support MDK v6 armclang compiler.
- 2.0.0
  - Initial version.

# **CRC**

The current CRC driver version is 2.0.3.

- 2.0.3
  - Bug fix:
    - \* Fix MISRA issues.
- 2.0.2
  - Bug fix:
    - \* Fix MISRA issues.
- 2.0.1
  - Bug fix:

- \* DATA and DATALL macro definition moved from header file to source file.
- 2.0.0
  - Initial version.

### **DMA**

The current DMA driver version is 2.1.1.

- 2.1.1
  - Improvements
    - \* Corrected the dma channel feature macro from FSL\_FEATURE\_DMAMUX\_MODUL-E\_CHANNEL to FSL\_FEATURE\_DMA\_MODULE\_CHANNEL.
- 2.1.0
  - Improvements
    - \* Added api DMA\_PrepareTransferConfig to expose option address increment.
    - \* Added api DMA\_EnableAutoStopRequest to support auto stop request feature.
- 2.0.2
  - Bug Fixes
    - \* Fixed violations of MISRA C-2012 rule 10.4, 10.3, 14.4, 16.4, 11.6, 10.1.
- 2.0.1
  - Bug Fixes
    - \* By adding parenthesis, fixed the build fail of DMA driver due to rule 12.5, MISRA C 2004.
- 2.0.0
  - Initial version.

#### **DMAMUX**

The current DMAMUX driver version is 2.0.5.

- 2.0.5
  - Improvements
    - \* Added feature FSL\_FEATURE\_DMAMUX\_CHCFG\_REGISTER\_WIDTH for the difference of CHCFG register width.
- 2.0.4
  - Bug Fixes
    - \* Fixed violations of MISRA C-2012 rule 10.4.
- 2.0.3
  - Bug Fixes
    - \* Fixed the issue for MISRA-2012 check.
      - · Fixed rule 10.4 and rule 10.3.
- 2.0.2
  - New Features
    - \* Added an always-on enable feature to a DMA channel for ULP1 DMAMUX support.

- 2.0.1
  - Bug Fixes
    - \* Fixed the build warning issue by changing the type of parameter source from uint8\_t to uint32\_t when setting DMA request source in DMAMUX\_SetSourceChange.
- 2.0.0
  - Initial version.

# **EWM**

The current EWM driver version is 2.0.3.

- 2.0.3
  - Bug Fixes
    - \* Fixed violation of MISRA C-2012 rules: 10.1, 10.3.
- 2.0.2
  - Bug Fixes
    - \* Fixed violation of MISRA C-2012 rules: 10.3, 10.4.
- 2.0.1
  - Bug Fixes
    - \* Fixed the hard fault in EWM\_Deinit.
- 2.0.0
  - Initial version.

### **FLASH**

Current FLASH driver version is 3.1.2

- 3.1.2
  - Bug Fixes Remove redundant comments.
- 3.1.1
  - Bug Fixes MISRA C-2012 issue fixed: rule 10.3
- 3.1.0
  - New Feature
    - \* Support erase flash asynchronously.
- 3.0.2
  - Bug Fixes MISRA C-2012 issue fixed: rule 8.4, 17.7, 10.4, 16.1, 21.15, 11.3, 10.7 building warning -Wnull-dereference on arm compiler v6
- 3.0.1
  - New Features
    - \* Added support FlexNVM alias for (kw37/38/39).
- 3.0.0
  - Improvements
    - \* Reorganized FTFx flash driver source file.
    - \* Extracted flash cache driver from FTFx driver.

- \* Extracted flexnym flash driver from FTFx driver.
- 2.3.1
  - Bug Fixes
    - \* Unified Flash IFR design from K3.
    - \* New encoding rule for K3 flash size.
- 2.3.0
  - New Features
    - \* Added support for device with LP flash (K3S/G).
    - \* Added flash prefetch speculation APIs.
  - Improvements
    - \* Refined flash\_cache\_clear function.
    - \* Reorganized the member of flash\_config\_t struct.
- 2.2.0
  - New Features
    - \* Supported FTFL device in FLASH\_Swap API.
    - \* Supported various pflash start addresses.
    - \* Added support for KV58 in cache clear function.
    - \* Added support for device with secondary flash (KW40).
  - Bug Fixes
    - \* Compiled execute-in-ram functions as PIC binary code for driver use.
    - \* Added missed flexram properties.
    - \* Fixed unaligned variable issue for execute-in-ram function code array.
- 2.1.0
  - Improvements
    - \* Updated coding style to align with KSDK 2.0.
    - \* Different-alignment-size support for pflash and flexnym.
    - \* Improved the implementation of execute-in-ram functions.
- 2.0.0
  - Initial version

# **GPIO**

The current driver version is 2.6.0.

- 2.6.0
  - New Features
    - \* Added API to get GPIO version information.
    - \* Added API to control a pin for general purpose input.
    - \* Added some APIs to control pin in secure and previliege status.
- 2.5.3
  - Bug Fixes
    - \* Correct the feature macro typo: FSL\_FEATURE\_GPIO\_HAS\_NO\_INDEP\_OUTPUT\_-CONTORL.
- 2.5.2

- Improvements
  - \* Improved GPIO\_PortSet/GPIO\_PortClear/GPIO\_PortToggle functions to support devices without Set/Clear/Toggle registers.
- 2.5.1
  - Bug Fixes
    - \* Fixed wrong macro definition.
    - \* Fixed MISRA C-2012 rule issues in the FGPIO\_CheckAttributeBytes() function.
    - \* Defined the new macro to separate the scene when the width of registers is different.
    - \* Removed some redundant macros.
  - New Features
    - \* Added some APIs to get/clear the interrupt status flag when the port doesn't control pins' interrupt.
- 2.4.1
  - Improvements
    - \* Improved GPIO\_CheckAttributeBytes() function to support 8 bits width GACR register.
- 2.4.0
  - Improvements
    - \* API interface added:
      - · New APIs were added to configure the GPIO interrupt clear settings.
- 2.3.2
  - Bug Fixes
    - \* Fixed the issue for MISRA-2012 check.
      - · Fixed rule 3.1, 10.1, 8.6, 10.6, and 10.3.
- 2.3.1
  - Improvements
    - \* Removed deprecated APIs.
- 2.3.0
  - New Features
    - \* Updated the driver code to adapt the case of interrupt configurations in GPIO module. New APIs were added to configure the GPIO interrupt settings if the module has this feature on it.
- 2.2.1
  - Improvements
    - \* API interface changes:
      - · Refined naming of APIs while keeping all original APIs by marking them as deprecated. The original APIs will be removed in next release. The main change is updating APIs with prefix of \_PinXXX() and \_PortXXX.
- 2.1.1
  - Improvements
    - \* API interface changes:
      - · Added an API for the check attribute bytes.
- 2.1.0
  - Improvements
    - \* API interface changes:
      - · Added "pins" or "pin" to some APIs' names.

10

· Renamed " PinConfigure" to "GPIO PinInit".

# I<sub>2</sub>C

The current I2C driver version is 2.0.9.

- 2.0.9
  - Bug Fixes
    - \* Fixed the MISRA-2012 violations.
      - · Fixed rule 8.4, 10.1, 10.4, 13.5, 20.8.
- 2.0.8
  - Bug Fixes
    - \* Fixed the bug that DFEN bit of I2C Status register 2 could not be set in I2C MasterInit.
    - \* MISRA C-2012 issue fixed: rule 14.2, 15.7, and 16.4.
    - \* Eliminated IAR Pa082 warnings from I2C\_MasterTransferDMA and I2C\_Master-TransferCallbackDMA by assigning volatile variables to local variables and using local variables instead.
    - \* Fixed MISRA issues.
      - · Fixed rules 10.1, 10.3, 10.4, 11.9, 14.4, 15.7, 17.7.
  - Improvements
    - \* Improved timeout mechanism when waiting certain state in transfer API.
    - \* Updated the I2C\_WAIT\_TIMEOUT macro to unified name I2C\_RETRY\_TIMES.
    - \* Moved the master manually acknowledge byte operation into static function I2C\_Master-AckByte.
    - \* Fixed control/status clean flow issue inside I2C\_MasterReadBlocking to avoid potential issue that pending status is cleaned before it's proceeded.
- 2.0.7
  - Bug Fixes
    - \* Fixed the issue for MISRA-2012 check.
      - · Fixed rule 11.9, 15.7, 14.4, 10.4, 10.8, 10.3, 10.1, 10.6, 13.5, 11.3, 13.2, 17.7, 5.7, 8.3, 8.5, 11.1, 16.1.
    - \* Fixed Coverity issue of unchecked return value in I2C RTOS Transfer.
    - \* Fixed variable redefine issue by moving i2cBases from fsl\_i2c.h to fsl\_i2c.c.
  - Improvements
    - \* Added I2C MASTER FACK CONTROL macro to enable FACK control for master transfer receive flow with IP supporting double buffer, then master could hold the SCL by manually setting TX AK/NAK during data transfer.
- 2.0.6
  - Bug Fixes
    - \* Fixed the issue that I2C Master transfer APIs(blocking/non-blocking) did not support the situation of master transfer with subaddress and transfer data size being zero, which means no data followed by the subaddress.
- 2.0.5

**NXP Semiconductors** 

- Improvements

\* Added I2C\_WATI\_TIMEOUT macro to allow the user to specify the timeout times for waiting flags in functional API and blocking transfer API.

#### • 2.0.4

- Bug Fixes
  - \* Added a proper handle for transfer config flag kI2C\_TransferNoStartFlag to support transmit with kI2C\_TransferNoStartFlag flag. Support write only or write+read with no start flag; does not support read only with no start flag.

#### • 2.0.3

- Bug Fixes
  - \* Removed enableHighDrive member in the master/slave configuration structure because the operation to HDRS bit is useless, the user need to use DSE bit in port register to configure the high drive capability.
  - \* Added register reset operation in I2C\_MasterInit and I2C\_SlaveInit APIs. Fixed issue where I2C could not switch between master and slave mode.
  - \* Improved slave IRQ handler to handle the corner case that stop flag and address match flag come synchronously.

#### • 2.0.2

- Bug Fixes
  - \* Fixed issue in master receive and slave transmit mode with no stop flag. The master could not succeed to start next transfer because the master could not send out re-start signal.
  - \* Fixed the out-of-order issue of data transfer due to memory barrier.
  - \* Added hold time configuration for slave. By leaving the SCL divider and MULT reset values when configured to slave mode, the setup and hold time of the slave is then reduced outside of spec for lower baudrates. This can cause intermittent arbitration loss on the master side.
- New Features
  - \* Added address nak event for master.
  - \* Added general call event for slave.

#### • 2.0.1

- New Features
  - \* Added double buffer enable configuration for SoCs which have the DFEN bit in S2 register.
  - \* Added flexible transmit/receive buffer size support in I2C\_SlaveHandleIRQ.
  - \* Added start flag clear, address match, and release bus operation in I2C\_SlaveWrite/Read-Blocking API.
- Bug Fixes
  - \* Changed the kI2C\_SlaveRepeatedStartEvent to kI2C\_SlaveStartEvent.
- 2.0.0
  - Initial version.

### **IRTC**

The current IRTC driver version is 2.1.1.

- 2.1.1
  - Bug Fixes
    - \* MISRA C-2012 issue check.
      - · Fixed rules, containing: rule-10.1, rule-10.3, rule-10.4.
- 2.1.0
  - Bug Fixes
    - \* Fixed incorrect leap year check in IRTC\_CheckDatetimeFormat.
  - New Feature
    - \* Added new APIs for new feature FSL FEATURE RTC HAS SUBSYSTEM.
    - \* Added new APIs for TAMPER, TAMPER QUEUE status get and clear.
    - \* Added new API to enable/disable 32 kHz RTC OSC clock during RTC register write.
    - \* Updated IRTC\_SetTamperParams to support new feature FSL\_FEATURE\_RTC\_HAS\_-FILTER23\_CFG
    - \* Updated irtc\_config\_t to exclude member wakeupSelect for new feature FSL\_FEATUR-E\_RTC\_HAS\_NO\_CTRL2\_WAKEUP\_MODE.
- 2.0.2
  - Bug Fixes
    - \* MISRA C-2012 issue check.
      - Fixed rules, containing: rule-10.1, rule-10.3, rule-10.4, rule-10.6, rule-10.8, rule-11.9, rule-12.2, rule-15.5, rule-16.4, rule-17.7.
- 2.0.1
  - Bug Fixes
    - \* Fixed the issue of hard code in IRTC\_Init.
- 2.0.0
  - Initial version.

# **LLWU**

The current LLWU driver version is 2.0.5.

- 2.0.5
  - Bug Fixes
    - \* Fixed violations of the MISRA C-2012 rules 10.3.
    - \* Fixed the issue that function LLWU\_SetExternalWakeupPinMode() does not work on 32-bit width platforms.
- 2.0.4
  - Bug Fixes
    - \* Fixed violations of the MISRA C-2012 rules 10.3, 10.4, 10.6, 10.7, 11.3.
    - \* Fixed issue that LLWU\_ClearExternalWakeupPinFlag may clear other filter flags by mistake on platforms with 32-bit LLWU registers.
- 2.0.3
  - Bug Fixes
    - \* Fixed MISRA-2012 rules.
      - · Rule 16.4.

- 2.0.2
  - Improvements
    - \* Corrected driver function LLWU\_SetResetPinMode parameter name.
  - Bug Fixes
    - \* Fixed MISRA-2012 rules.
      - · Rule 14.4, 10.8, 10.4, 10.3.
- 2.0.1
  - Other Changes
    - \* Updates for KL8x.
- 2.0.0
  - Initial version.

# **LPTMR**

The current LPTMR driver version is 2.1.1.

- 2.1.1
  - Improvements
    - \* Updated the characters from "PTMR" to "LPTMR" in "FSL\_FEATURE\_PTMR\_HAS\_NO\_PRESCALER\_CLOCK\_SOURCE\_1\_SUPPORT" feature definition.
- 2.1.0
  - Improvements
    - \* Implement for some special devices' not supporting for all clock sources.
  - Bug Fixes
    - \* Fixed issue when accessing CMR register.
- 2.0.2
  - Bug Fixes
    - \* Fixed MISRA-2012 issues.
      - · Rule 10.1.
- 2.0.1
  - Improvements
    - \* Updated the LPTMR driver to support 32-bit CNR and CMR registers in some devices.
- 2.0.0
  - Initial version.

### **PIT**

The current PIT driver version is 2.0.4.

- 2.0.4
  - Bug Fixes
    - \* Fixed PIT\_SetTimerPeriod implementation, the load value trigger should be PIT clock cycles minus 1.
- 2.0.3

- Bug Fixes
  - \* Clear all status bits for all channels to make sure the status of all TCTRL registers is clean.
- 2.0.2
  - Bug Fixes
    - \* Fixed MISRA-2012 issues.
      - · Rule 10.1.
- 2.0.1
  - Bug Fixes
    - \* Cleared timer enable bit for all channels in function PIT\_Init() to make sure all channels stay in disable status before setting other configurations.
    - \* Fixed MISRA-2012 rules.
      - · Rule 14.4, rule 10.4.
- 2.0.0
  - Initial version.

# **PMC**

The current PMC driver version is 2.0.3.

- 2.0.3
  - Bug Fixes
    - \* Fixed the violation of MISRA C-2012 rule 11.3.
- 2.0.2
  - Bug Fixes
    - \* Fixed the violations of MISRA 2012 rules:
      - · Rule 10.3.
- 2.0.1
  - Bug Fixes
    - \* Fixed MISRA issues.
      - · Rule 10.8, Rule 10.3.
- 2.0.0
  - Initial version.

# **PORT**

The current PORT driver version is 2.3.0.

- 2.3.0
  - New Features
    - \* Added new APIs for Electrical Fast Transient(EFT) detect.
    - \* Added new API to configure port voltage range.
- 2.2.0
  - New Features
    - \* Added new api PORT\_EnablePinDoubleDriveStrength.

- 2.1.1
  - Bug Fixes
    - \* Fixed the violations of MISRA C-2012 rules: 10.1, 10.411.311.8, 14.4.
- 2.1.0
  - New Features
    - \* Updated the driver code to adapt the case of the interrupt configurations in GPIO module. Will move the pin configuration APIs to GPIO module.
- 2.0.2
  - Other Changes
    - \* Added feature guard macros in the driver.
- 2.0.1
  - Other Changes
    - \* Added "const" in function parameter.
    - \* Updated some enumeration variables' names.

# **QTMR**

The current QTMR driver version is 2.0.1.

- 2.0.1
  - Bug Fixes
    - \* MISRA C-2012 issue check.
      - Fixed rules, containing: rule-10.1, rule-10.3, rule-10.4, rule-11.9, rule-14.4, rule-15.5, rule-17.7.
    - \* Changed FSL\_COMPONENT\_ID as platform.drivers.qtmr\_2.
- 2.0.0
  - Initial version.

### **RCM**

The current RCM driver version is 2.0.4.

- 2.0.4
  - Bug Fixes
    - \* Fixed violation of MISRA C-2012 rule 10.3
- 2.0.3
  - Bug Fixes
    - \* Fixed violation of MISRA C-2012 rules.
- 2.0.2
  - Bug Fixes
    - \* Fixed MISRA issue.
      - · Rule 10.8, rule 10.1, rule 13.2, rule 3.1.
- 2.0.1
  - Bug Fixes

- \* Fixed kRCM\_SourceSw bit shift issue.
- 2.0.0
  - Initial version.

# SIM

The current SIM driver version is 2.1.3.

- 2.1.3
  - Improvements
    - \* Updated function SIM\_GetUniqueId to support different register names.
- 2.1.2
  - Bug Fixes
    - \* Fixed SIM\_GetUniqueId bug that could not get UIDH.
- 2.1.1
  - Bug Fixes
    - \* Fixed violations of the MISRA C-2012 rules 10.1, 10.4
- 2.1.0
  - Improvements
    - \* Added new APIs: SIM\_GetRfAddr() and SIM\_EnableSystickClock().
- 2.0.0
  - Initial version.

# **SLCD**

The current SLCD driver version is 2.0.3.

- 2.0.3
  - Bug Fixes
    - \* Fixed SLCD\_Init bug that some bit-fileds are cleared by mistake.
- 2.0.2
  - Bug Fixes
    - \* Fixed violations of the MISRA C-2012 rules 3.1, 10.1, 10.3, 10.3, 10.4 11.4, 17.7
- 2.0.1
  - Bug Fixes
    - \* Changed the Blink mode start setting flow.
  - Other Changes
    - \* Added static to SLCD global variables.
- 2.0.0
  - Initial version.

# **SMC**

The current SMC driver version is 2.0.7.

- 2.0.7
  - Bug Fixes
    - \* Fixed MISRA-2012 issue 10.3.
- 2.0.6
  - Bug Fixes
    - \* Fixed issue for MISRA-2012 check.
      - Fixed rule 10.3, rule 11.3.
- 2.0.5
  - Bug Fixes
    - \* Fixed issue for MISRA-2012 check.
      - Fixed rule 15.7, rule 14.4, rule 10.3, rule 10.1, rule 10.4.
- 2.0.4
  - Bug Fixes
    - \* When entering stop modes, used RAM function for the flash synchronization issue. Application should make sure that, the RW data of fsl\_smc.c is located in memory region which is not powered off in stop modes.
- 2.0.3
  - Improvements
    - \* Added APIs SMC\_PreEnterStopModes, SMC\_PreEnterWaitModes, SMC\_PostExitWait-Modes, and SMC\_PostExitStopModes.
- 2.0.2
  - Bug Fixes
    - \* Added DSB before WFI while ISB after WFI.
  - Other Changes
    - \* Updated SMC\_SetPowerModeVlpw implementation.
- 2.0.1
  - Other Changes
    - \* Updated for KL8x.
- 2.0.0
  - Initial version.

## SPI

The current SPI driver version is 2.1.1.

- 2.1.1
  - Bug Fixes
    - \* Fixed MISRA 10.3 violation.
- 2.1.0
  - Improvements
    - \* Added timeout mechanism when waiting certain states in transfer driver.

MCUXpresso SDK Release Notes Supporting twrkm34z50mv3

# - Bug Fixes

- \* Fixed the bug that, when working as a slave, instance that does not have FIFO may miss some rx data.
- \* Fixed master RX data overflow issue by synchronizing transmit and receive process.
- \* Fixed issue that slave should not share the same non-blocking initialization API and IRQ handler with master to prevent dead lock issue.
- \* Fixed issue that callback should be invoked after all data is sent out to bus.
- \* Added code in SPI\_SlaveTransferNonBlocking to empty rx buffer before initializing transfer.

#### • 2.0.5

# - Bug Fixes

- \* Eliminated Pa082 warnings from SPI WriteNonBlocking and SPI GetStatusFlags.
- \* Fixed MISRA issues.
  - · Fixed issues 10.1, 10.3, 10.4, 10.7, 10.8, 11.9, 14.4, 17.7.

#### • 2.0.4

### - New Features

- \* Supported 3-wire mode for SPI driver. Added new API SPI\_SetPinMode() to control the transfer direction of the single wire. For master instance, MOSI is selected as I/O pin. For slave instance, MISO is selected as I/O pin.
- \* Added dummy data setup API to allow users to configure the dummy data to be transferred.

#### • 2.0.3

# - Bug Fixes

\* Fixed the potential interrupt race condition at high baudrate when calling API SPI\_Master-TransferNonBlocking.

#### • 2.0.2

#### New Features

- \* Allowed users to set the transfer size for SPI\_TransferNoBlocking non-integer times of watermark.
- \* Allowed users to define the dummy data. Users only need to define the macro SPI\_DUM-MYDATA in applications.

#### • 2.0.1

#### - Bug Fixes

- \* Fixed SPI\_Enable function parameter error.
- \* Set the s\_dummy variable as static variable in fsl\_spi\_dma.c.

### - Improvements

- \* Optimized the code size while not using transactional API.
- \* Improved performance in polling method.
- \* Added #ifndef/#endif to allow users to change the default tx value at compile time.

#### • 2.0.0

- Initial version.

# **SPI DMA Driver**

The current SPI DMA driver version is 2.1.1.

- 2.1.1
  - Bug Fixes
    - \* Fixed the bug that TX data not sent to bus when transfer finish callback is called.
- 2.1.0
  - Improvements
    - \* Added timeout mechanism when waiting certain states in transfer driver.
  - Bug Fixes
    - \* Fixed the bug that, when working as a slave, instance that does not have FIFO may miss some rx data.
    - \* Fixed master RX data overflow issue by synchronizing transmit and receive process.
    - \* Fixed issue that slave should not share the same non-blocking initialization API and IRQ handler with master to prevent dead lock issue.
    - \* Fixed issue that callback should be invoked after all data is sent out to bus.
    - \* Added code in SPI\_SlaveTransferNonBlocking to empty rx buffer before initializing transfer.
- 2.0.5
  - Bug Fixes
    - \* Eliminated Pa082 warnings from SPI\_WriteNonBlocking and SPI\_GetStatusFlags.
    - \* Fixed MISRA issues.
      - · Fixed issues 10.1, 10.3, 10.4, 10.7, 10.8, 11.9, 14.4, 17.7.
- 2.0.4
  - New Features
    - \* Supported 3-wire mode for SPI driver. Added new API SPI\_SetPinMode() to control the transfer direction of the single wire. For master instance, MOSI is selected as I/O pin. For slave instance, MISO is selected as I/O pin.
    - \* Added dummy data setup API to allow users to configure the dummy data to be transferred.
- 2.0.3
  - Bug Fixes
    - \* Fixed the potential interrupt race condition at high baudrate when calling API SPI\_Master-TransferNonBlocking.
- 2.0.2
  - New Features
    - \* Allowed users to set the transfer size for SPI\_TransferNoBlocking non-integer times of watermark.
    - \* Allowed users to define the dummy data. Users only need to define the macro SPI\_DUM-MYDATA in applications.
- 2.0.1
  - Bug Fixes
    - \* Fixed SPI\_Enable function parameter error.
    - \* Set the s\_dummy variable as static variable in fsl\_spi\_dma.c.
  - Improvements

20

- \* Optimized the code size while not using transactional API.
- \* Improved performance in polling method.
- \* Added #ifndef/#endif to allow users to change the default tx value at compile time.
- 2.0.0
  - Initial version.

# **SPI FreeRTOS Driver**

The current SPI FreeRTOS driver version is 2.1.0.

- 2.1.0
  - Improvements
    - \* Added timeout mechanism when waiting certain states in transfer driver.
  - Bug Fixes
    - \* Fixed the bug that, when working as a slave, instance that does not have FIFO may miss some rx data.
    - \* Fixed master RX data overflow issue by synchronizing transmit and receive process.
    - \* Fixed issue that slave should not share the same non-blocking initialization API and IRQ handler with master to prevent dead lock issue.
    - \* Fixed issue that callback should be invoked after all data is sent out to bus.
    - \* Added code in SPI\_SlaveTransferNonBlocking to empty rx buffer before initializing transfer.
- 2.0.5
  - Bug Fixes
    - \* Eliminated Pa082 warnings from SPI\_WriteNonBlocking and SPI\_GetStatusFlags.
    - \* Fixed MISRA issues.
      - · Fixed issues 10.1, 10.3, 10.4, 10.7, 10.8, 11.9, 14.4, 17.7.
- 2.0.4
  - New Features
    - \* Supported 3-wire mode for SPI driver. Added new API SPI\_SetPinMode() to control the transfer direction of the single wire. For master instance, MOSI is selected as I/O pin. For slave instance, MISO is selected as I/O pin.
    - \* Added dummy data setup API to allow users to configure the dummy data to be transferred.
- 2.0.3
  - Bug Fixes
    - \* Fixed the potential interrupt race condition at high baudrate when calling API SPI\_Master-TransferNonBlocking.
- 2.0.2
  - New Features
    - \* Allowed users to set the transfer size for SPI\_TransferNoBlocking non-integer times of watermark.
    - \* Allowed users to define the dummy data. Users only need to define the macro SPI\_DUM-MYDATA in applications.

WECAPITSSUSPIX Recease Notes Supporting (WIRMS-4250MV)

- 2.0.1
  - Bug Fixes
    - \* Fixed SPI\_Enable function parameter error.
    - \* Set the s\_dummy variable as static variable in fsl\_spi\_dma.c.
  - Improvements
    - \* Optimized the code size while not using transactional API.
    - \* Improved performance in polling method.
    - \* Added #ifndef/#endif to allow users to change the default tx value at compile time.
- 2.0.0
  - Initial version.

# **UART**

The current UART driver version is 2.5.1.

- 2.5.1
  - Improvements
    - \* Use separate data for TX and RX in uart\_transfer\_t.
  - Bug Fixes
    - \* Fixed bug that when ring buffer is used, if some data is received in ring buffer first before calling UART\_TransferReceiveNonBlocking, the received data count returned by UART\_TransferGetReceiveCount is wrong.
- 2.5.0
  - New Features
    - \* Added APIs UART\_GetRxFifoCount/UART\_GetTxFifoCount to get rx/tx FIFO data count.
    - \* Added APIs UART\_SetRxFifoWatermark/UART\_SetTxFifoWatermark to set rx/tx FIFO water mark.
  - Bug Fixes
    - \* Fixed bug of race condition during UART transfer using transactional APIs, by disabling and re-enabling the global interrupt before and after critical operations on interrupt enable registers.
    - \* Fixed DMA/eDMA transfer blocking issue by enabling tx idle interrupt after DMA/eDMA transmission finishes.
- 2.4.0
  - New Features
    - \* Added APIs to configure 9-bit data mode, set slave address and send address.
- 2.3.0
  - Bug Fixes
    - \* Fixed the bug that, when framing/parity/noise/overflow flag or idle line detect flag is set, receive FIFO should be flushed to avoid FIFO pointer being in unknown state, since FIFO has no valid data.
  - Improvements
    - \* Modified UART\_TransferHandleIRQ so that txState will be set to idle only when all data

has been sent out to bus.

- \* Modified UART\_TransferGetSendCount so that this API returns the real byte count that UART has sent out rather than the software buffer status.
- \* Added timeout mechanism when waiting for certain states in transfer driver.

#### • 2.2.0

- New Features
  - \* Added UART hardware FIFO enable/disable API.
- Improvements
  - \* Added check for kUART\_TransmissionCompleteFlag in UART\_TransferHandleIRQ, U-ART\_SendEDMACallback and UART\_TransferSendDMACallback to ensure all the data would be sent out to bus.
- Bug Fixes
  - \* Eliminated IAR Pa082 warnings from UART\_TransferGetRxRingBufferLength, UART\_GetEnabledInterrupts, UART\_GetStatusFlags and UART\_TransferHandleIRQ.
  - \* Added code in UART\_ReadBlocking so that if more than one receiver errors occur, all status flags will be cleared and the most severe error status will be returned.
  - \* Fixed MISRA issues.
    - · Fixed rules 10.1, 10.3, 10.4, 14.4, 11.6, 17.7.

#### • 2.1.6

- Bug Fixes
  - \* Fixed the issue of register's being in repeatedly reading status while performing the IRQ routine.
- 2.1.5
  - Improvements
    - \* Added hardware flow control function support.
    - \* Added idle-line-detecting feature in UART\_TransferNonBlocking function. If an idle line is detected, a callback will be triggered with status kStatus\_UART\_IdleLineDetected returned. This feature may be useful when the number of received bytes is less than the expected receive data size. Before triggering the callback, data in the FIFO is read out (if it has FIFO), and no interrupt will be disabled except for the case that the receive data size reaches 0.
    - \* Enabled the RX FIFO watermark function. With the idle-line-detecting feature enabled, you can set the watermark value to whatever you want (should not be bigger than the RX FIFO size). Data is then received and a callback will be triggered when data receive ends.

### • 2.1.4

- Improvements
  - \* Changed parameter type in UART\_RTOS\_Init() struct rtos\_uart\_config -> uart\_rtos\_config t.
- Bug Fixes
  - \* Disabled UART receive interrupt instead of global interrupt when reading data from ring buffer. With ring buffer used, receive nonblocking will disable global interrupt to protect the ring buffer. This has a negative effect on other IPs using interrupt.
- 2.1.3
  - New Features
    - \* Added RX framing error and parity error status check when using interrupt transfer.

MCUXpresso SDK Release Notes Supporting twrkm34z50mv3

- 2.1.2
  - Bug Fixes
    - \* Fixed baud rate fine adjust bug to make the computed baud rate more accurate.
- 2.1.1
  - Bug Fixes
    - \* Removed needless check of event flags and assert in UART\_RTOS\_Receive.
    - \* Always waited for RX event flag in UART\_RTOS\_Receive.
- 2.1.0
  - Improvements
    - \* Added transactional API.
- 2.0.0
  - Initial version.

# **UART DMA**

The current UART\_DMA driver version is 2.5.0.

- 2.5.0
  - Refer UART driver change log 2.1.0 to 2.5.0

# **UART FREERTOS**

The current UART\_FREERTOS driver version is 2.5.0.

- 2.5.0
  - Refer UART driver change log 2.1.0 to 2.5.0

### **VREF**

The current VREF driver version is 2.1.2.

- 2.1.2
  - Bug Fixes
    - \* Fixed the violation of MISRA-2012 rule 10.3.
    - \* Fixed MISRA C-2012 rule 10.3, rule 10.4 violation.
- 2.1.1
  - Bug Fixes
    - \* MISRA-2012 issue fixed.
      - · Fixed rules containing: rule-10.4, rule-10.3, rule-10.1.
- 2.1.0
  - Improvements
    - \* Added new functions to support L5K board: added VREF\_SetTrim2V1Val() and VREF\_GetTrim2V1Val() functions to supply 2V1 output mode.
- 2.0.0

- Initial version.

## **WDOG**

The current WDOG driver version is 2.0.1.

- 2.0.1
  - Bug Fixes
    - \* MISRA C-2012 issue fixed: rule 10.3, 10.4, 10.6, 10.7 11.9 and 17.7.
- 2.0.0
  - Initial version.

# **XBAR**

The current XBAR driver version is 2.1.0.

- 2.1.0
  - Improvements
    - \* Improved to support XBAR which has less than 4 interrupt output.
  - Bug Fixes
    - \* Fixed violations of MISRA C-2012 rule 12.2.
- 2.0.5
  - Bug Fixes
    - \* Fixed violations of the MISRA C-2012 rules 10.1, 10.3, 10.4, 10.6, 10.7, 10.8, 12.2, 18.1, 20.7.
- 2.0.4
  - Bug Fixes
    - \* Fixed IAR build warning Pa082.
- 2.0.3
  - Improvements
    - \* Optimized XBAR\_SetOutputSignalConfig.
- 2.0.2
  - Bug Fixes
    - \* Corrected configuration for function XBAR\_SetOutputSignalConfig.
- 2.0.1
  - Bug Fixes
    - \* Fixed w1c bits for XBAR\_SetOutputSignalConfig function.
- 2.0.0
  - Initial version.

# 2 Component Change Log SERIAL\_MANAGER

The current Serial\_Manager component version is 1.0.2.

- 1.0.2
  - Add SerialManager\_WriteTimeDelay()/SerialManager\_ReadTimeDelay() for serial manager's read/write non-blocking mode.
- 1.0.1
  - Add prefixing fsl\_component\_xxx/fsl\_adapter\_xxx.
- 1.0.0
  - Initial version

How to Reach Us:

Home Page:

nxp.com

Web Support:

nxp.com/support

Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.-com/SalesTermsandConditions.

While NXP has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, Freescale, the Freescale logo, Kinetis, Processor Expert, and Tower are trademarks of NXP B.V. All other product or service names are the property of their respective owners. Arm, Cortex, Keil, Mbed, Mbed Enabled, and Vision are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org. © 2021 NXP B.V.

